home *** CD-ROM | disk | FTP | other *** search
/ CU Amiga Super CD-ROM 6 / CU Amiga Magazine's Super CD-ROM 06 (1996)(EMAP Images)(GB)(Track 1 of 4)[!][issue 1997-01].iso / cucd / magazine / executive_v2.00 / data / developers.lzx / SysInfo / gcc / os-include / inline / SysInfo.h
C/C++ Source or Header  |  2002-10-12  |  5KB  |  192 lines

  1. #ifndef _INLINE_SYSINFO_H
  2. #define _INLINE_SYSINFO_H
  3.  
  4. #include <sys/cdefs.h>
  5. #include <inline/stubs.h>
  6.  
  7. __BEGIN_DECLS
  8.  
  9. #ifndef BASE_EXT_DECL
  10. #define BASE_EXT_DECL
  11. #define BASE_EXT_DECL0 extern struct Library * SysInfoBase;
  12. #endif
  13. #ifndef BASE_PAR_DECL
  14. #define BASE_PAR_DECL
  15. #define BASE_PAR_DECL0 void
  16. #endif
  17. #ifndef BASE_NAME
  18. #define BASE_NAME SysInfoBase
  19. #endif
  20.  
  21. BASE_EXT_DECL0
  22.  
  23. extern __inline struct SI_Notify *
  24. AddNotify (BASE_PAR_DECL struct SysInfo * si,WORD flags,LONG safety_limit)
  25. {
  26.   BASE_EXT_DECL
  27.   register struct SI_Notify * _res  __asm("d0");
  28.   register struct Library *a6 __asm("a6") = BASE_NAME;
  29.   register struct SysInfo * a0 __asm("a0") = si;
  30.   register WORD d0 __asm("d0") = flags;
  31.   register LONG d1 __asm("d1") = safety_limit;
  32.   __asm __volatile ("jsr a6@(-0x4e)"
  33.   : "=r" (_res)
  34.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1)
  35.   : "a0","a1","d0","d1", "memory");
  36.   return _res;
  37. }
  38. extern __inline void 
  39. FreeSysInfo (BASE_PAR_DECL struct SysInfo * si)
  40. {
  41.   BASE_EXT_DECL
  42.   register struct Library *a6 __asm("a6") = BASE_NAME;
  43.   register struct SysInfo * a0 __asm("a0") = si;
  44.   __asm __volatile ("jsr a6@(-0x24)"
  45.   : /* no output */
  46.   : "r" (a6), "r" (a0)
  47.   : "a0","a1","d0","d1", "memory");
  48. }
  49. extern __inline void 
  50. GetCpuUsage (BASE_PAR_DECL struct SysInfo * si,struct SI_CpuUsage * usage)
  51. {
  52.   BASE_EXT_DECL
  53.   register struct Library *a6 __asm("a6") = BASE_NAME;
  54.   register struct SysInfo * a0 __asm("a0") = si;
  55.   register struct SI_CpuUsage * a1 __asm("a1") = usage;
  56.   __asm __volatile ("jsr a6@(-0x5a)"
  57.   : /* no output */
  58.   : "r" (a6), "r" (a0), "r" (a1)
  59.   : "a0","a1","d0","d1", "memory");
  60. }
  61. extern __inline void 
  62. GetLoadAverage (BASE_PAR_DECL struct SysInfo * si,struct SI_LoadAverage * la)
  63. {
  64.   BASE_EXT_DECL
  65.   register struct Library *a6 __asm("a6") = BASE_NAME;
  66.   register struct SysInfo * a0 __asm("a0") = si;
  67.   register struct SI_LoadAverage * a1 __asm("a1") = la;
  68.   __asm __volatile ("jsr a6@(-0x2a)"
  69.   : /* no output */
  70.   : "r" (a6), "r" (a0), "r" (a1)
  71.   : "a0","a1","d0","d1", "memory");
  72. }
  73. extern __inline LONG 
  74. GetNice (BASE_PAR_DECL struct SysInfo * si,LONG which,LONG who)
  75. {
  76.   BASE_EXT_DECL
  77.   register LONG  _res  __asm("d0");
  78.   register struct Library *a6 __asm("a6") = BASE_NAME;
  79.   register struct SysInfo * a0 __asm("a0") = si;
  80.   register LONG d0 __asm("d0") = which;
  81.   register LONG d1 __asm("d1") = who;
  82.   __asm __volatile ("jsr a6@(-0x42)"
  83.   : "=r" (_res)
  84.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1)
  85.   : "a0","a1","d0","d1", "memory");
  86.   return _res;
  87. }
  88. extern __inline LONG 
  89. GetPgrp (BASE_PAR_DECL struct SysInfo * si)
  90. {
  91.   BASE_EXT_DECL
  92.   register LONG  _res  __asm("d0");
  93.   register struct Library *a6 __asm("a6") = BASE_NAME;
  94.   register struct SysInfo * a0 __asm("a0") = si;
  95.   __asm __volatile ("jsr a6@(-0x3c)"
  96.   : "=r" (_res)
  97.   : "r" (a6), "r" (a0)
  98.   : "a0","a1","d0","d1", "memory");
  99.   return _res;
  100. }
  101. extern __inline LONG 
  102. GetPid (BASE_PAR_DECL struct SysInfo * si)
  103. {
  104.   BASE_EXT_DECL
  105.   register LONG  _res  __asm("d0");
  106.   register struct Library *a6 __asm("a6") = BASE_NAME;
  107.   register struct SysInfo * a0 __asm("a0") = si;
  108.   __asm __volatile ("jsr a6@(-0x30)"
  109.   : "=r" (_res)
  110.   : "r" (a6), "r" (a0)
  111.   : "a0","a1","d0","d1", "memory");
  112.   return _res;
  113. }
  114. extern __inline LONG 
  115. GetPpid (BASE_PAR_DECL struct SysInfo * si)
  116. {
  117.   BASE_EXT_DECL
  118.   register LONG  _res  __asm("d0");
  119.   register struct Library *a6 __asm("a6") = BASE_NAME;
  120.   register struct SysInfo * a0 __asm("a0") = si;
  121.   __asm __volatile ("jsr a6@(-0x36)"
  122.   : "=r" (_res)
  123.   : "r" (a6), "r" (a0)
  124.   : "a0","a1","d0","d1", "memory");
  125.   return _res;
  126. }
  127. extern __inline LONG 
  128. GetTaskCpuUsage (BASE_PAR_DECL struct SysInfo * si,struct SI_TaskCpuUsage * usage,struct Task * task)
  129. {
  130.   BASE_EXT_DECL
  131.   register LONG  _res  __asm("d0");
  132.   register struct Library *a6 __asm("a6") = BASE_NAME;
  133.   register struct SysInfo * a0 __asm("a0") = si;
  134.   register struct SI_TaskCpuUsage * a1 __asm("a1") = usage;
  135.   register struct Task * a2 __asm("a2") = task;
  136.   __asm __volatile ("jsr a6@(-0x60)"
  137.   : "=r" (_res)
  138.   : "r" (a6), "r" (a0), "r" (a1), "r" (a2)
  139.   : "a0","a1","a2","d0","d1", "memory");
  140.   return _res;
  141. }
  142. extern __inline struct SysInfo *
  143. InitSysInfo (BASE_PAR_DECL0)
  144. {
  145.   BASE_EXT_DECL
  146.   register struct SysInfo * _res  __asm("d0");
  147.   register struct Library *a6 __asm("a6") = BASE_NAME;
  148.   __asm __volatile ("jsr a6@(-0x1e)"
  149.   : "=r" (_res)
  150.   : "r" (a6)
  151.   : "a0","a1","d0","d1", "memory");
  152.   return _res;
  153. }
  154. extern __inline void 
  155. RemoveNotify (BASE_PAR_DECL struct SysInfo * si,struct SI_Notify * notify)
  156. {
  157.   BASE_EXT_DECL
  158.   register struct Library *a6 __asm("a6") = BASE_NAME;
  159.   register struct SysInfo * a0 __asm("a0") = si;
  160.   register struct SI_Notify * a1 __asm("a1") = notify;
  161.   __asm __volatile ("jsr a6@(-0x54)"
  162.   : /* no output */
  163.   : "r" (a6), "r" (a0), "r" (a1)
  164.   : "a0","a1","d0","d1", "memory");
  165. }
  166. extern __inline LONG 
  167. SetNice (BASE_PAR_DECL struct SysInfo * si,LONG which,LONG who,LONG nice)
  168. {
  169.   BASE_EXT_DECL
  170.   register LONG  _res  __asm("d0");
  171.   register struct Library *a6 __asm("a6") = BASE_NAME;
  172.   register struct SysInfo * a0 __asm("a0") = si;
  173.   register LONG d0 __asm("d0") = which;
  174.   register LONG d1 __asm("d1") = who;
  175.   register LONG d2 __asm("d2") = nice;
  176.   __asm __volatile ("jsr a6@(-0x48)"
  177.   : "=r" (_res)
  178.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2)
  179.   : "a0","a1","d0","d1","d2", "memory");
  180.   return _res;
  181. }
  182.  
  183. #undef BASE_EXT_DECL
  184. #undef BASE_EXT_DECL0
  185. #undef BASE_PAR_DECL
  186. #undef BASE_PAR_DECL0
  187. #undef BASE_NAME
  188.  
  189. __END_DECLS
  190.  
  191. #endif /* _INLINE_SYSINFO_H */
  192.